-
Notifications
You must be signed in to change notification settings - Fork 849
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[WIP] Multizone discrete adjoints for turbomachinery #2317
base: develop
Are you sure you want to change the base?
Conversation
@joshkellyjak @pcarruscag Should I make some first commits for a "tag type / debug" recording to this branch? (This problem is the main motivation but technically it's quite unrelated.) We need it here, but it might be better to merge it from a dedicated branch. |
…l write restart files during runtime (there is a bug, potentially when clearing the tape).
Personally I would like this to selfishly enhance my understanding, but I don't think it should be merged when we complete the PR. Could be useful documentation for the website. |
Well I think the functionality should be merged at some point. It might become too much for this PR(?). Let me just go ahead and create a dedicated branch for the tag tape. We could just use that branch as a helper then and prepare it for develop after this one is merged. |
Ah now I got the comment. I would keep adding the debug tape separate from fixing the turbo issues |
…zation.hpp (to cover RealReverseTag).
Reverting an accidental merge |
…his is a temporary change to avoid false positives when a tag tape is used. They might be unnecessary anyway though.
SU2_CFD/src/solvers/CEulerSolver.cpp
Outdated
|
||
visc_numerics->SetSecondary(S_domain, S_boundary); | ||
|
||
/*--- Turbulent kinetic energy ---*/ | ||
|
||
if (config->GetKind_Turb_Model() == TURB_MODEL::SST) | ||
visc_numerics->SetTurbKineticEnergy(solver_container[TURB_SOL]->GetNodes()->GetSolution(iPoint,0), | ||
solver_container[TURB_SOL]->GetNodes()->GetSolution(iPoint,0)); | ||
|
||
/*--- Compute and update residual ---*/ | ||
|
||
auto residual = visc_numerics->ComputeResidual(config); | ||
LinSysRes.SubtractBlock(iPoint, residual); | ||
|
||
/*--- Jacobian contribution for implicit integration ---*/ | ||
|
||
if (implicit) | ||
if (config->GetKind_TimeIntScheme() == EULER_IMPLICIT) | ||
Jacobian.SubtractBlock2Diag(iPoint, residual.jacobian_i); | ||
|
||
} | ||
/*--- Store number of Newton iterations at BC ---*/ | ||
if(config->GetKind_FluidModel() == DATADRIVEN_FLUID) | ||
nodes->SetNewtonSolverIterations(iPoint, GetFluidModel()->GetnIter_Newton()); | ||
|
||
} | ||
END_SU2_OMP_FOR | ||
} | ||
|
||
/*--- Free locally allocated memory ---*/ | ||
delete [] Normal; | ||
|
||
delete [] Velocity_b; | ||
delete [] Velocity_i; | ||
|
||
delete [] S_boundary; | ||
delete [] delta_c; | ||
delete [] deltaprim; | ||
delete [] cj; | ||
for (iVar = 0; iVar < nVar; iVar++) | ||
for (unsigned short iVar = 0; iVar < nVar; iVar++) | ||
{ | ||
delete [] R_Matrix[iVar]; | ||
} | ||
for (iVar = 0; iVar < nVar-1; iVar++) | ||
for (unsigned short iVar = 0; iVar < nVar-1; iVar++) | ||
{ | ||
delete [] R_c_inv[iVar]; | ||
delete [] R_c[iVar]; | ||
} | ||
delete [] R_Matrix; | ||
delete [] R_c; | ||
delete [] R_c_inv; | ||
delete [] R; | ||
delete [] c_avg; | ||
delete [] dcjs; | ||
|
||
delete [] AverageTurboMach; | ||
delete [] UnitNormal; | ||
delete [] turboNormal; | ||
delete [] turboVelocity; | ||
} | ||
|
||
void CEulerSolver::BC_Giles_Total_Inlet( CNumerics *conv_numerics, CConfig *config, unsigned short val_marker, | ||
su2double *&c_avg, su2double *&R, su2double **&R_c_inv, su2double **&R_c, unsigned short iSpan, unsigned short SpanwisePosition) { | ||
|
||
/*--- Calculates boundry condition for quasi-3D and 1D total boundary conditions ---*/ | ||
|
||
/*--- Retrieve the specified boundary conditions. ---*/ | ||
auto const Marker_Tag = config->GetMarker_All_TagBound(val_marker); | ||
auto P_Total = config->GetGiles_Var1(Marker_Tag); | ||
auto T_Total = config->GetGiles_Var2(Marker_Tag); | ||
auto const FlowDir = config->GetGiles_FlowDir(Marker_Tag); | ||
auto const alphaIn_BC = atan(FlowDir[1]/FlowDir[0]); | ||
|
||
su2double gammaIn_BC = 0; | ||
if (nDim == 3){ | ||
gammaIn_BC = FlowDir[2]; //atan(FlowDir[2]/FlowDir[0]); | ||
} | ||
|
||
/*--- Non-dim. the inputs---*/ | ||
P_Total /= config->GetPressure_Ref(); | ||
T_Total /= config->GetTemperature_Ref(); | ||
|
||
/* --- Computes the total state --- */ | ||
GetFluidModel()->SetTDState_PT(P_Total, T_Total); | ||
auto const Enthalpy_BC = GetFluidModel()->GetStaticEnergy()+ GetFluidModel()->GetPressure()/GetFluidModel()->GetDensity(); | ||
auto const Entropy_BC = GetFluidModel()->GetEntropy(); | ||
|
||
/* --- Computes the inverse matrix R_c --- */ | ||
conv_numerics->ComputeResJacobianGiles(GetFluidModel(), AveragePressure[val_marker][iSpan], AverageDensity[val_marker][iSpan], | ||
AverageTurboVelocity[val_marker][iSpan], alphaIn_BC, gammaIn_BC, R_c, R_c_inv); | ||
|
||
GetFluidModel()->SetTDState_Prho(AveragePressure[val_marker][SpanwisePosition], AverageDensity[val_marker][SpanwisePosition]); | ||
auto AverageEnthalpy = GetFluidModel()->GetStaticEnergy() + AveragePressure[val_marker][SpanwisePosition]/AverageDensity[val_marker][SpanwisePosition]; | ||
auto AverageEntropy = GetFluidModel()->GetEntropy(); | ||
|
||
|
||
su2double avgVel2 = 0.0; | ||
for (unsigned short iDim = 0; iDim < nDim; iDim++) avgVel2 += AverageVelocity[val_marker][iSpan][iDim]*AverageVelocity[val_marker][iSpan][iDim]; |
Check notice
Code scanning / CodeQL
Long switch case Note
MIXING_IN_1D (89 lines)
Switch has at least one case that is too long:
Proposed Changes
This is, for now, a brief note on @joshkellyjak 's and my WIP on a discrete adjoint functionality for multizone (multi-stage, multi-row) turbomachinery cases. We intend to realize everything through the native multizone discrete adjoint solver, though some turbo-specific problems need to be resolved.
This will, probably, involve further additions/corrections/cleanups around the mixing plane interface so that it is recorded properly. The current recording seems to still be not fully correct.
Related Work
None, so far.